/*
  学习目标：多表单元素-代码优化
   1. state控制表单元素的value或checked属性
   2. onChange配合setState修改数据
*/

import React from 'react';

export default class App extends React.Component {
  state = {
    username: '',
    desc: '',
    city: '2',
    isSingle: true,
  };

  handleChange = (e) => {
    const { name, type, checked, value } = e.target;
    this.setState({
      [name]: type === 'checkbox' ? checked : value,
    });
  };

  render() {
    const { username, desc, city, isSingle } = this.state;
    return (
      <div>
        姓名：
        <input
          name="username"
          type="text"
          onChange={this.handleChange}
          value={username}
        />
        <br />
        描述：
        <textarea
          name="desc"
          onChange={this.handleChange}
          value={desc}
        ></textarea>
        <br />
        城市：
        <select name="city" value={city} onChange={this.handleChange}>
          <option value="1">北京</option>
          <option value="2">上海</option>
          <option value="3">广州</option>
          <option value="4">深圳</option>
        </select>
        <br />
        是否单身：
        <input
          name="isSingle"
          onChange={this.handleChange}
          checked={isSingle}
          type="checkbox"
        />
      </div>
    );
  }
}
